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MULTIUSER DETECTOR FOR VARIABLE SPREADING FACTORS 

BACKGROUND OF THE INVENTION 
Field of the Invention 

The present invention relates generally to multiple access digital 
communication systems. More specifically, the invention relates to a multiuser 
detector system and method for the simultaneous reception of data from multiple 
users having different spreading factors. 

Description of the Related Art 

A multiple-access communication system allows a plurality of users to access 
the same communication medium to transmit or receive information. The media may 
comprise, for example, a network cable in a local area network or lan, a copper wire 
in the classic telephone system, or an air interface for wireless communication. 

A prior art multiple access communication system is shown in FIG. 1. The 
communication media is referred to as a communication channel. Communication 
techniques such as frequency division multiple access or FDMA, time division 
multiple access or TDMA, carrier sense multiple access or CSMA, code division 
multiple access or CDMA and others allow access to the same communication 
medium for more than one user. These techniques can be mixed together creating 
hybrid varieties of multiple access schemes. For example, time division duplex or 
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TDD mode of the proposed third generation W-CDMA standard is a combination 
ofTDMA and CDMA. 

An example CDMA prior art communication system is shown in FIG. 2. 
CDMA is a communication technique in which data is transmitted with a broadened 
band (spread spectrum) by modulating the data to be transmitted with a pseudo-noise 
signal. The data signal to be transmitted may have a bandwidth of only a few 
thousand Hertz distributed over a frequency band that may be several million Hertz. 
The communication channel is being used simultaneously by K independent 
subchannels. For each subchannel, all other subchannels appear as interference. 

As shown, a single subchannel of a given bandwidth is mixed with a unique 
spreading code which repeats a predetermined pattern generated by a wide 
bandwidth, pseudo-noise (pn) sequence generator. These unique user spreading 
codes are typically pseudo-orthogonal to one another such that the cross-correlation 
between the spreading codes is close to zero. A data signal is modulated with the pn 
sequence producing a digital spread spectrum signal. A carrier signal is then 
modulated with the digital spread spectrum signal and transmitted in dependence 
upon the transmission medium. A receiver demodulates the transmission extracting 
the digital spread spectrum signal. The transmitted data is reproduced after 
correlation with the matching pn sequence. When the spreading codes are 
orthogonal to one another, the received signal can be correlated with a particular user 
signal related to the particular spreading code such that only the desired user signal 
related to the particular spreading code is enhanced while the other signals for all 
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other users are not enhanced. 

Each value of the spreading code is known as a chip and has a chip rate that 
is the same or faster than the data rate. The ratio between the chip rate and the 
subchannel data rate is the spreading factor. 

To extend the possible range of values of the data signal, a symbol is used to 
represent more than two binary values. Ternary and quaternary symbols take on 
three and four values respectively. The concept of a symbol allows for a greater 
degree of information since the bit content of each symbol dictates a unique pulse 
shape. Depending upon the number of symbols used, an equal number of unique 
pulse or wave shapes exist. The information at the source is converted into symbols 
which are modulated and transmitted through the subchannel for demodulation at the 
destination. 

The spreading codes in a CDMA system are chosen to minimize interference 
between a desired subchannel and all other subchannels. Therefore, the standard 
approach to demodulating the desired subchannel has been to treat all other 
subchannels as interference, similar to interference that manifests itself in the 
communication medium. Receivers designed for this process are single-user, 
matched filter and RAKE receivers. 

Since different subchannels do interfere with each other somewhat, another 
approach is to demodulate all subchannels at a receiver. The receiver can listen to 
all of the users transmitting at once by running a decoding algorithm for each of 
them in parallel . This ideology is known as multiuser detection. Multiuser detection 
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can provide a significant performance improvement over single-user receivers. 

Referring to FIG. 3, a system block diagram of a prior art CDMA receiver 
using a multiuser detector is shown. As one skilled in this art realizes, the receiver 
may include such functions as radio frequency or rf down conversion and associated 
filtering for radio frequency channels, analog-to-digital conversion or optical signal 
demodulation for a specific communication media. The output of the receiver is a 
processed signal, either analog or digital, containing the combined spread signals of 
all active subchannels. The multiuser detector performs multiuser detection and 
outputs a plurality of signals corresponding to each active subchannel. All or a 
smaller number of the total number of subchannels may be processed. 

Optimal multiuser detectors are computationally intensive devices performing 
numerous complex mathematic operations and are therefore difficult to implement 
economically. To minimize expense, suboptimal multiuser detectors such as linear 
detectors have been developed requiring less computational complexity as a 
compromise approximating the performance of optimal detectors. Linear detectors 
include decorrelators, minimum mean square error or MMSE detectors, and zero- 
forcing block linear equalizers or ZF-BLEs. 

A system block diagram of a prior art linear multiuser detector for 
synchronous or asynchronous CDMA communication is shown in FIG. 4. Data 
output from the communication media specific receiver (as in FIG. 3) is coupled to 
a subchannel estimator which estimates the impulse response of each symbol 
transmitted in a respective subchannel. The linear detector uses the impulse response 
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estimates along with a subchannel' s spreading code to demodulate each subchannel' s 
data. The data is output to subchannel data processing blocks for respective users. 

To effect parallel detection of K subchannel users in a physical system, linear 
multiuser detector methods are executed as fixed gate arrays, microprocessors, digital 
signal processors or DSPs and the like. Fixed logic systems allow for greater system 
speed while microprocessor driven systems offer programming flexibility. Either 
implementation that is responsible for the multiuser detection performs a sequence 
of mathematic operations. To describe the functions, the following variables 
typically define the structure and operation of a linear multiuser detector: 



K = the total number of users/transmitters that are active in the system. 

N c = the number of chips in a data block. The number of chips is 
required since with varying spreading factors this number is a measure 
common to all users. The number of chips is divisible by the largest 
spreading factor allowed. For the case of synchronous CDMA, a 
symbol from the user with the largest spreading factor may constitute 
a block of data. Therefore, N c can be reduced to be equal to the largest 
spreading factor. 

W = the communication channel impulse response length in chips. 
This is generally a predefined parameter of the system. 
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Q {k) = the spreading factor of user k. The spreading factor is equal to 
the number of chips that are used to spread a symbol of user's data. A 
system knows the spreading factors in advance and does not need to 
estimate them from the received data. 

N s {k) = the number of symbols sent by user k. N s {k) = N C / Q {k \ 

K 

Nf= ^N[ k> = the total number of symbols sent. 

(P k) = the data (information) sent by user k. The data is presented in the 
form of a vector, where a vector is an array of data indexed by a single 
index variable. For the purposes of vector and matrix operations 
which follow, all vectors are defined as column vectors. The n th 
element of cf k) is the n th symbol transmitted by the K h user. 

h {k) = the impulse response of the subchannel experienced by user k 
presented as a vector. This quantity needs to be estimated at the 
receiver. The receiver's estimates of the subchannel impulse 
responses are referred to as h {k \ The elements of the vector h {k) are 
typically complex numbers, which model both amplitude and phase 
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variations that can be introduced by the subchannel. 

v {k) = the spreading code of user k y presented as a vector. For the 
purposes of linear multiuser detection, it is useful to think of vectors 
containing the section of the spreading code which spreads a particular 
symbol. Therefore, the vector v {k/l) is defined as the spreading code 
which is used to spread the n lh symbol sent by the K h user 
Mathematically, it is defined as: v/ M = v, w for (n-l)Q {k) +l z i z nQ ik) 
and 0 for all other i, where i is the index of vector elements. 

I s ® = a vector which represents user k's data, spread by the spreading 
sequence v (k) and transmitted through that user's subchannel h (k) . The 
vector r* k) represents channel observations performed during the period 
of time when a block of data arrives. The i th element of the vector r* k) 
can be defined as: 




Equation 1 



The signal received at the receiver includes all user signals r** } plus noise. Therefore, 
we can define the received data vector r as follows: 
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K 



r = 2 r ^ + 



Equation 2 



The vector m in Equation 2 represents noise introduced by the communication 
channel. 

FIG. 5 shows a system and method of a prior art linear multiuser detector. 
The estimated subchannel impulse response vectors h {k) and the spreading codes v (k) 
are used to create a system transmission response matrix for each user k. A matrix 
is a block of numbers indexed by two indexing variables and is arranged as a 
rectangular grid, with the first indexing variable being a row index and the second 
indexing variable being a column index. 

A system transmission response matrix for user k is typically denoted as A {k \ 
The /"'-row, jAcolumn element is denoted as A in (k) and is defined as: 



Each column of the matrix A m corresponds to a matched filter response for a 
particular symbol sent by user k during the period of interest. Referring back to FIG. 
5, the received data r is matched to a combination of all user's spreading codes and 
subchannel impulse responses. Therefore, A ik) contains N s (k) matched filterresponses. 



w 



A, 



= y h (k) v 



(k,n) 
i - j + I 



Equation 3 



WO 01/22610 PCT/US00/02621 

transmission response matrix, denoted as A is created by concatenating the system 
transmission matrices for all the users as shown below: 



A—[A\..^A Equation 7 

In accordance with prior art modulation techniques, the elements of h ik) can 
be complex numbers. It then follows that the non-zero elements of A can be 
complex numbers. 

An example total system transmission response matrix A for a hypothetical 
prior art multiuser detector assembled in accordance with Equations 4, 5, 6 and 7 is 
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for two (k = 2) users, A 0) and A (2) , having sixteen chips in a data block (N c = 16), a 
channel impulse response length of four (W= 4) and a spreading factor for the first 
user of two (Q {1) = 2) and a spreading factor for the second user of four (Q (2) = 4). 
In the resultant total system transmission response matrix A, bj k) denotes the i th 
element of the combined system and channel response for the n th symbol of the k h 
user. 

The received data r is processed using the total system transmission response 
matrix A which represents a bank of matched filter responses to create a vector of 
matched-filter outputs which is denoted as y. The matched filtering operation is 
defined as 

y = A r - Equation 9 

The matrix A H represents the Hermitian (or complex) transpose of the matrix 

A. The Hermitian transpose is defined as ^ =A }i where the over-bar denotes the 

operation of taking a conjugate of a complex number. The matched filter outputs are 
then multiplied by the inverse of an objective matrix O. The objective matrix O 
represents the processing which differentiates each type of linear receiver model. It 
is derived from the system transmission matrix A. 

The zero-forcing block linear equalizer (ZF-BLE) receiver is a linear receiver 
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with an objective matrix specified as O = A H A. The minimum mean square error 
block linear equalizer (MMSE-BLE) receiver is a linear receiver with an objective 
matrix specified as O = A H A + &l where <? is the variance of the noise present on 
each of the symbols of the received data vector r and the matrix / is known as an 
identity matrix. An identity matrix is square and symmetric with Is on its main 
diagonal and zeros everywhere else. The size of the identity matrix is chosen so as 
to make the addition operation valid according to the rules of linear algebra. 

For a decorrelator (decorrelating receiver), matrix A is simplified by ignoring 
the channel responses h ik \ considering only the spreading codes and their cross- 
correlation (interference) properties. A cross-correlation matrix, commonly referred 
to as /?, is generally constructed for decorrelator type receivers. This matrix can be 
constructed by assuming that W=l and h t {k) =\ in the definition of A above (i.e. the 
channel response of every subchannel is an impulse). Then the cross correlation 
matrix R is the objective matrix O as defined for the ZF-BLE receiver. A 
decorrelator often serves as a sub-process of a more complex multiuser detection 
receiver. Once the objective matrix is created, the multiuser detector will invert the 
matrix, denoted as O'K 

The inverse of the objective matrix is then multiplied by the matched filter 
output vector y to produce estimates of the data vector d where ^(estimate) = Or x y. 
The inversion of the objective matrix O is a complex, computationally intensive 
process. The number of operations required to perform this process increase as the 
cube of the size of the matrix O. For most asynchronous CDMA receivers, the size 
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of O is very large which makes the process of inversion impracticable. 

To overcome this limitation, and to make the system physically realizable, a 
numerical method due to Cholesky is used. Cholesky decomposition can 
significantly reduce the computational complexity of inverting the matrix O if the 
5 matrix is banded. 

A banded matrix is a square matrix that contains non-zero values only on 
several diagonals away from the main diagonal. The number of non-zero diagonals 
adjacent to the main diagonal that have at least one non-zero element is referred to 
as bandwidth. Thus, a symmetric matrix M is said to be banded with bandwidth p 
10 if 

m i} = 0 for all j>i + p, Equation 10 

where m i} is an element of M, with i being the row index and j the column index. For 
a banded matrix with size denoted as n and bandwidth denoted as p, Cholesky 
decomposition can reduce the required numeric operations of inverting the objective 
15 matrix 0 from varying as the cube of the size of the matrix, n 3 , to varying as the size 

of the matrix times the square of the bandwidth, np 2 . 

As discussed above, the objective matrix for a ZF-BLE receiver is O = A H A. 
To illustrate the numeric complexity, the objective matrix O for the total system 
response matrix A shown in Equation 6 is 
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Equation 1 1 



where zeros denote all elements that by mathematical operation yield zero and with 
x's representing non-zero values. If the non-zero elements of the r* row and/* 
column of the total system response matrix A do not have the same vector index, then 
the corresponding element of objective matrix 0 with row index i and column index 
; will be 0. The bandwidth of O (Equation 1 1) is equal to 9 since there are non-zero 
elements as far as nine columns away from the main diagonal. 

The objective matrix O as it is constructed in the prior art receiver shown in 
FIG. 5 is not well banded. Therefore, Cholesky decomposition cannot be used 
effectively to reduce the operational complexity when inverting matrix O. However, 
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the prior art discloses that when all users transmit with equal spreading factors, a re- 
arrangement of the total system transmission response matrix A can be performed 
prior to calculating an objective matrix O, turning matrix O into a banded matrix. 
A system block diagram for this process is shown in FIG. 6. 

The process which computes the column re-arrangement of matrix A performs 
the re-arrangement without any additional information. The re-arrangement reduces 
the operational complexity when inverting the matrix. Once the detection procedure 
is complete, a user data vector d is computed, a reversed re-arrangement process is 
performed descrambling vector d back to its original form for further processing. 

In a typical asynchronous CDMA system, the bandwidth of a re-arranged 
objective matrix is at least ten times less than its original size. Therefore, a savings 
of at least a factor of 100 in processing time is achieved when Cholesky 
decomposition is performed on an objective matrix based upon a re-arranged total 
system response matrix. However, the prior art has not addressed a re-arrangement 
method for when different spreading factors are in use between active users. 

Accordingly, there exists a need to determine a method to reduce the number 
of inversion steps when different spreading factors are in use. 

SUMMARY OF THE INVENTION 
The present invention relates to a multiuser detector that detects and decodes 
synchronous or asynchronous CDMA subchannels having different spreading factors 
with reduced computational complexity. The multiuser detector of the present 
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invention is compatible with ZF-BLE, MMSE, decorrelating detectors and the like 
using Cholesky decomposition to minimize numeric operations. The system and 
method arranges the columns of system transmission response matrices representing 
the response characteristics of individual users into a well-banded total system 
transmission response matrix which represents a plurality of matched-filter responses 
for a given block of received data. The invention in conjunction with Cholesky 
decomposition reduces the number of required mathematic operations prior to 
parallel matched filtering. 

Accordingly, it is an object of the invention to detect a plurality of users 
transmitting over a CDMA interface with reduced computational complexity where 
each user may employ a different spreading factor. 

It is another object of the invention to use existing linear detectors in a 
multiuser detector without requiring a uniform spreading factor among all CDMA 
subchannels. 

It is a further object of the invention to efficiently limit the bandwidth of a 
matrix that represents a plurality of matched filters prior to inversion. 

Other objects and advantages of the system and the method will become 
apparent to those skilled in the art after reading the detailed description of the 
preferred embodiment. 



BRIEF DESCRIPTION OF THE DRAWINGS 
FIG, 1 is a simplified block diagram of a prior art multiple access 
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communication system. 

FIG. 2 is a simplified block diagram of a prior art CDMA communication 
system. 

FIG. 3 is a simplified block diagram of a prior art CDMA receiver with 
multiuser detection. 

FIG. 4 is a simplified block diagram of a prior art multiuser detector. 
FIG. 5 is a block diagram of a prior art linear multiuser detector. 
FIG. 6 is a block diagram of a prior art linear multiuser detector using 
Cholesky decomposition. 

FIG. 7 is block diagram of a linear multiuser detector of the present 
invention. 

FIG. 8 depicts system transmission response matrix A (k) top and bottom 
column offsets. 

FIG. 9 depicts matrix column index value assignment. 

FIGs. 10A and 10B are flow diagrams of an alternative method implementing 
the present invention. 

FIG. 1 1 depicts the steps for assembling a spreading factor group matrix A G te) . 

FIG. 12 depicts the steps for assembling an A ' matrix in accordance with the 
present invention. 



DETAILED DESCRIPTION OF THE INVENTION 
The embodiments will be described with reference to the drawing figures 
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where like numerals represent like elements throughout. 

Shown in FIG. 7 is a multiuser detector 17 of the present invention for 
detecting, after reception, a plurality of users transmitting over a common CDMA 
channel. The multiuser detector 17 comprises a plurality of processors having 
collateral memory which perform various vector and matrix operations. Alternate 
embodiments of the invention include fixed gate arrays and DSPs performing the 
functions of the various processors. The detector 17 also comprises a first input 19 
for inputting individual k subchannel impulse response estimates modeled as vectors 
h {k) to correct intersymbol interference or ISI caused by a subchannel's own symbols 
and multiple access interference or MAI caused by symbols from other user's 
subchannels for all received data signals, a second input 21 for inputting data from 
all users k transmitted in a discreet block of time in the form of an input vector r 
containing the combined data from each user's subchannel and an output 23 for 
outputting user data d m for each user k from the received channel data r in the form 
of an output vector. The total number of users K and the spreading factor Q {k) 41 for 
each user (k = 1, 2, 3... K) are known a priori. 

To obtain user data d {k) for a specific user from the combined user data r, the 
user data must be filtered using a matched filter 25 or the like* One knowledgeable 
in this art recognizes that a matched filter 25 requires a response characteristic which 
is the complex conjugate of the combination of the spread pulse shape and the user's 
subchannel impulse response to produce an output with a level representative of the 
signal prior to transmission. Signals input to the filter 25 which do not match with 
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a given response characteristic produce a lower output. 

Each individual k subchannel impulse response estimate h {k) is input to a first 
memory 27 where it is combined with the same user's spreading code 29 (Equation 
3) creating a system transmission response estimate matrix A (k) for that user. An 
arrangement processor 33 of the present invention 17 performs a re-ordering of all 
matrix A n ik) columns. The arrangement method 99 requires that each subchannel 
system transmission response matrix A {k) have the column structure defined by 
Equation 4 which is typical of linear receivers. If the system transmission response 
matrices A ik) are not of the form defined by Equation 4, the arrangement processor 
33 first re-arranges the columns to the structure defined by Equation 4. The present 
invention 17 does not require that all system transmission response matrices A {k) be 
concatenated into a total system transmission response matrix A as defined by 
Equation 7. 

The arrangement processor 33 examines each system transmission response 
matrix A {1 \ A a \ A°\ ... A {k) column for the number of zero-value elements from the 
support of each vector b n {k) (Equation 4) defining top o (k) Tn and bottom offsets o ik) Bn 
as shown in FIG. 8 (for one matrix). As previously described, each system 
transmission response matrix A (k) has the same number of rows; only the number of 
columns vary. As shown in FIG, 9, the arrangement processor 33 assigns an index 
value n t for each column of each system transmission response matrices A (k) based 
upon their respective top o {k) Tn and bottom o {k) Bn offsets. The column values are 
assigned in the order of increasing magnitude from columns having minimal top 
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offset with maximum bottom offset to columns having maximum top offset with 
minimal bottom offset. 

If two columns are encountered where one has a greater top offset and a 
greater bottom offset than another, if the difference between top offsets is greater 
than the difference between bottom offsets, the column with the lower top offset is 
assigned the lower index n*. If the difference between bottom offsets is greater than 
the difference between top offsets, the column with the greater bottom offset is 
assigned the lower index ft,. If the differences between top and bottom offsets are 
equal either of the two columns can be assigned the lower index it,. 
The arrangement processor 33 assembles a total system transmission response matrix 
A' in the order of the assigned column indices n k . The column indices it, are retained 
in memory 33 for use during the descrambling process 45, As an example, using the 
total system response matrices A (1) andi4 (2) described and shown in Equation 8, the 
arrangement method 99 of the present invention 17 produces the total system 
transmission response matrix A shown below 
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The arrangement method 99 indexed the eight columns (1-8) of system transmission 
response matrix A (1) and the four columns (9-12) of system transmission response matrix 
A (2) in an order of 1, 9, 2, 3, 10, 4, 5, 1 1, 6, 7, 12, 8 to create a well-banded total system 
transmission response matrix A (Equation 12). 

The arrangement method 99 embodiment described above involves an 
examination of each system transmission response matrix A U) , A a \ A <3) , ... A {k) 
comparing each column with every other column for top o ik) Tn and bottom o ik) Bn offsets. 
Given the special structure of each system transmission response matrix A {k \ namely, 
that the columns of each matrix are arranged in order of increasing top offsets and 
decreasing bottom offsets as you progress from left to right (reference Equation 8, 
matrices A il) and A (2) ), an alternative method 199 can be performed without having to 
examine each system transmission response matrix A {k) directly. 

The alternative method 199 is shown in FIGs. 10A and 10B. All system 
transmission response matrices A ik) corresponding (step 201) to users having equal 
spreading factors are grouped together (step 203). For each spreading factor group g, 
memories are allocated within the processor 33 capable of storing all of the columns 
from all system transmission matrices A (1) , A (2) , A (3) , ... A ( *\ The spreading factor groups 
g are arranged in order of increasing spreading factor. 

An exemplary system illustrating the performance of the present invention 199 
contains seven users having four different spreading factors Q w assigned as follows: 

User 1 (g (1) ) = 8 User 2 (Q {1) ) = 8 User 3 (fi (3) ) = 8 User 4 (0 (4) ) = 32 
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User 5 (fi (5) ) = 16 User 6 = 16 User 7 (g (7) ) = 4. 



Using the system and method 199 of the present invention 17, the system transmission 
response matrices A {k) are separated into spreading factor groups: 
group 1 (spreading factor 4) A (7) 
5 group 2 (spreading factor 8) A (1) , A (2) , A (3) 

group 3 (spreading factor 16) A (5 \ A {6) 

group 4 (spreading factor 32) A^\ 
A respective spreading factor group g comprises at least one system transmission 
response matrix A ik \ where each matrix A ik) is arbitrarily indexed from 1 to LPK Each 
10 spreading factor group g is indexed according to increasing spreading factor magnitude. 

Within each spreading factor group, the columns of the associated system 
transmission response matrices A {k) are assembled into common spreading factor group 
transmission response matrices A^, where g = 1, 2, 3, ... G (step 205). As shown in 
FIG, 11, the method 199 copies the first column of the system transmission response 
15 matrix having index One to the first blank column of A G ^ } ; the first column of the system 
transmission response matrix having index two to the second blank column of A G fe) ; 
continuing throughout the remaining system transmission response matrices in a 
respective spreading factor group g until all first columns are copied. The method 199 
proceeds with copying the second columns, the third columns, e/c, for each matrix A ik) 
20 in the respective spreading factor group A 0 (g) , 

All matrices in a spreading factor group g have the same number of columns due 
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to the same spreading factor. Therefore, the assembled spreading factor group 
transmission response matrices A G te) will have V s * times the number of columns in one 
associated system transmission response matrices A***. For equal spreading factors, the 
arrangement method as-applied to each individual system transmission response matrix 
per group is similar to prior art techniques for assembling a total system transmission 
response matrix A. 

To assemble a total system transmission response matrix A' accommodating 
variable spreading factors, the spreading factor group transmission response matrix A^ 
having the lowest spreading factor is copied sequentially (step 207) into memory 33a, 
beginning with the first column, i.e., column one of A G U) , to the first allocated column 
of A '. The spreading factor group transmission response matrix A 0 U) having the lowest 
spreading factor has the maximum number of columns. All other spreading factor group 
transmission response matrix columns will be inserted into this base matrix A'. 

If the system spreading factors are even integer multiples of each other (step 209), 
the processor 33 assembles the total system transmission matrix A' (step 211) by 
considering the remaining spreading factor group transmission matrices A G te) in any 
order (step 209). For each spreading factor group transmission matrix Ac 1 ", the 
processor 33 derives a column placement reference index m , 

Q(8) Qig) 

m-n- 



q(D 2-Q (l) Equation 13 
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where denotes the spreading factor associated with the spreading factor group 
transmission matrix A^ under consideration, Q {1) denotes the lowest spreading factor 
among all groups and n is the column of the spreading factor group transmission 
response matrix A^* under consideration where n = 1, 2, 3, ... N (step 211). 

To use the column placement index m , a reference location in A ' is derived (step 
215) using the total number of system transmission response matrices L (1) that constitute 
the spreading factor group matrix having the lowest spreading factor, 



The processor 33 derives a column set from the spreading factor group transmission 
response matrix A^ under consideration (step 217) using the number of system 
transmission response matrices that belong to the spreading factor group currently under 
consideration, 



The processor 33 copies the column set defined by Equation 15 from A^ and inserts 
it (step 219) into the base matrix A' after the column of A G (1) which has the reference 
location defined by Equation 14 as shown in FIG. 12. The remaining columns of the 
spreading factor group matrix under consideration are copied and inserted into the base 



wxL (,) . 



Equation 14 



L te) x (/i - 1) + 1 through L« x n. 



Equation 



15 
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matrix A' similarly (step 221). After all columns from one spreading factor group 
matrix are placed, the processor 33 chooses the next spreading factor group matrix A^ 
(step 223) and executes the above method. Equations 13, 14 and 15 allow the f 1 
columns from the remaining spreading factor group transmission matrices Aq^ to be 
placed in A ' after an m ,h column that has similar support (step 225). 

When the system spreading factors are not even integer multiples of each other, 
the right side expression of Equation 13 does not yield an integer. In this case, the 
processor 33 will round the result of Equation 13 to the nearest integer above or the 
nearest integer below the value (step 213). The rounding direction has negligible effect 
on overall system performance. The order in which the rest of the group system 
transmission matrices A^ are considered may have some effect on the system 
performance. A priori knowledge of the spreading factors can be used to choose an 
optimum order in advance. 

Using the arrangement techniques described above, and for the case when 
spreading factors are even integer multiples of each other, a matrix bandwidth B can be 
achieved which can be shown to be bounded as: 



W-\ 



tAX 



9 V* Qmax 



<B< 



J 



re 



W-l 



'MAX 



+ 1 



9 V* Qmax 
Li n {k) 



-1 



Equation 



16 



Equation 16 predicts that the bandwidth of the total system transmission response 
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matrix of Equation 1 1 will be between 3 and 6. An examination of Equation 12 reveals 
that the bandwidth after either arrangement method 99, 199 of the present invention 17 

is 4. 

The improvement the present invention 17 provides is further appreciated as the 
number of transmitted symbols increase. If a system transmitted 16,000 chips (800 
symbols for a first user and 400 symbols for a second user), the bandwidth of the matrix 
A H A would be approximately 800. Using the arrangement method 99 to produce a total 
system response matrix A, the bandwidth of A lH A 9 remains four since bandwidth 
(Equation 16) is independent of the number of transmitted symbols. After all of the 
elements of objective matrix O are derived, the inverse 41 is performed. Since the 
complexity of inverting a matrix is proportional to the square of its bandwidth, the 
present invention 17 provides a reduction of computational complexity by a factor of 
approximately (800/4) 2 =200 2 =40,000. 

The total system transmission response matrix A 1 provides the response 
characteristics to the matched-filter 25. Each column of the system response matrix A 9 
is a vector which represents the response characteristics of a particular symbol. The 
received data vector r is input to the matched-filter 25 where it is matched with every 
response characteristic from the total system transmission response matrix A ' to produce 
a matched filter output vector y. Each element of output vector y corresponds to a 
preliminary estimate of a particular symbol transmitted by a given user. The output 
vector y from the matched-filter 25 is loaded into a multiplier 43 with the inverted 
objective matrix 0. Both the matched-filter 25 output vector y and the inverted 
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objective matrix O are multiplied yielding a user data vector d. The user data vector d 
contains all of the data transmitted from all users during the discreet time block. Since 
the objective matrix O and the matched filter 25 output are based on the total system 
response matrix A', the user data vector d must be de-scrambled. The de-scrambling 
process 149 is the inverse of the arrangement methods 99, 199. 

A descrambler 45 re-arranges each element of the user data vector d based upon 
the column re-assignments performed while undergoing either arrangement method 99, 
199. The elements of the data vector d are in the same order dictated by the total 
transmission response matrix A, 1, 9, 2, 3, 10, 4, 5, 1 l f 6, 7, 12, 8, transposed vertically. 
The descramber 45 allocates a memory space having the same dimension and places 
each vector element in sequential order, 1-12. After the user data vector d is 
descrambled 149, the user data is output 23 for further processing. 

While the present invention has been described in terms of the preferred 
embodiment, other variations which are within the scope of the invention as outlined in 
the claims below will be apparent to those skilled in the art. 
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CLAIMS 

What is claimed is: 

1 . A method (99) for assembling on a processor a response matrix with limited 
matrix bandwidth from a plurality of individual response matrices representing a 
plurality of filter response characteristics, characterized by the steps of: 

(a) examining each column of each individual response matrix for vector top 
5 and bottom (o ik) Bn ) offsets; 

(b) assigning an index value (n f ) from 1 to n for each of said examined columns 
based upon said columns having a small top offset (o (k) Tn ) with a large bottom offset 
(o ik) B n) to said columns having a large top offset (p w n ) with a small bottom offset (o {k) Bn ) 
respectively; and 

10 (c) arranging said examined individual response matrix columns in accordance 

with said index values (n f ) according to increasing magnitude. 



2. The method (99) according to claim 1 wherein step (b) is further characterized 
by the steps of: 

(bl) obtaining a difference between top offsets (o {k) Tn ) and a difference between 
bottom offsets (<?%„) for two columns if a first column has a larger top offset (o (k) Tn ) and 
5 a larger bottom offset (o {k) Bn ) than a second column; 

(b2) comparing said top offset (o (k) Tn ) difference and said bottom offset (o m Bn ) 
difference yielding a greater top (o {k) Tn ) or bottom offset (o (k) Bn ) difference; and 

(b3) if said top offset (o {k) Tn ) difference is greater than said bottom offset (o {k) Bn ) 
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difference, assigning a lower index value for said column with a larger top offset (o {k) Tn ) 
difference. 



3. The method (99) according to claim 2 wherein step (b2) is further 
characterized by the step of: 

(b2a) if said bottom offset (o {k) Btl ) difference is greater than said top offset (o m Tn ) 
5 difference, assigning a lower index value for said column with a larger bottom offset 
(o%„) difference. 

4. A method (199) for assembling on a processor a response matrix with limited 
matrix bandwidth from a plurality of individual response matrices representing a 
plurality of filter response characteristics, characterized by the steps of: 

(a) grouping the plurality of individual response matrices according to like 
5 spreading factors (203); 

(b) assembling spreading factor group matrices (205) from said groups of 
individual response matrices with like spreading factors; and 

(c) forming a base total response matrix (207) from a spreading factor group 
matrix having the lowest spreading factor. 

5. The method (199) according to claim 4 further characterized by the steps of: 

(d) choosing one spreading factor group matrix for consideration from said 
remaining spreading factor group matrices (209); 
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(e) deriving a column placement reference (2 1 1 ) for a first column of said chosen 
spreading factor group matrix; 

(f) deriving a reference location (217) in said base total response matrix; 

(g) deriving a column set (219) from said chosen spreading factor group matrix; 

(h) inserting said column set after said column placement reference in said base 
total response matrix (221); 

(i) repeating steps (a) through (h) for each successive column of said spreading 
factor group matrix under consideration; and 

(j) repeating steps (a) through (i) (223) for remaining spreading factor group 
matrices. 

6. The method (199) according to claim 5 wherein step (e) is further 
characterized by the step of: 

(el) assigning a column placement reference index m (21 1) for said spreading 
factor group matrix under consideration using, 

Q(i) Q(g) 

m-n — — 

go) 2 .(2 (1) 

where denotes the spreading factor associated with the spreading factor group matrix 
under consideration, Q {1) denotes the lowest spreading factor among all groups and n is 
the column of the spreading factor group matrix under consideration where n = 1, 2, 3, 
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7. The method (199) according to claim 6 is further characterized by the step of 
rounding said column placement reference index m (215) if not an integer. 



8. The method (199) according to claim 7 wherein step (f) is further 
characterized by the step of: 

(f 1 ) assigning a reference location in said base total response matrix (2 1 7) using, 

mxL (,) 

5 where is total number of individual response matrices that constitute said spreading 
factor group matrix having the lowest spreading factor and m is said column placement 
reference index for said spreading factor group matrix under consideration. 

9. The method (199) according to claim 8 wherein step (g) is further 
characterized by the step of: 

(gl) assigning a column set from said spreading factor group matrix under 
consideration (219) using, 
5 L w x (n - 1) + 1 through x n 

where is said number of individual response matrices comprising said spreading 
factor group matrix under consideration. 

10. A method of detecting in a received CDMA communication if) a plurality 
of data communications each corresponding with a specific user (k) characterized by the 
steps of: 
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(a) acquiring impulse response estimates (19) for symbols within each data 
communication; 

(b) constructing a system transmission response matrix (27) for each of the user 

data 

communications (k) from said impulse response estimates (19); 

(c) assembling a well-banded total system transmission response matrix (3 1 , 33, 
37) from all of said user system transmission response matrices (27); 

(d) filtering (25) said received CDMA communication (r) with said total system 
transmission response matrix yielding a matched filter output; 

(e) forming an objective matrix (39) based upon said total system transmission 
response matrix; 

(0 inverting (41) said objective matrix; 

(g) multiplying (43) said matched filter output with said inverted objective matrix 
yielding estimated user data; 

(h) descrambling (45) said estimated user data yielding user data corresponding 
to the plurality of data communications; and 

(i) repeating steps (a)-(h) for a next CDMA communication. 

11. The method (99) according to claim 10 wherein step (c) is further 
characterized by the steps of: 

(cl) examining each of said system transmission response matrix columns for 
vector top (o {k) Tn ) and bottom (o (k) Btl ) offsets; 
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5 (c2) assigning an index value («,) from 1 to n for each of said examined columns 

based upon said columns having a small top offset (o {k) Tn ) with a large bottom offset 
(o {k) Bn ) ^ said columns having a large top offset (o {k) Tn ) with a small bottom offset (o {k) Bn ) 
respectively; and 

(c3) arranging said examined total system transmission response matrix columns 
10 in accordance with said index values («,.) according to increasing magnitude. 

12. The method (99) according to claim 11 wherein step (c2) is further 
characterized by the steps of: 

(c2a) obtaining a difference between top offsets (o ik) Tn ) and a difference between 
bottom offsets (o (k) Bn ) for two columns if a first column has a larger top offset (o (k) Tn ) and 
5 a larger bottom offset (o {k) Bn ) than a second column; 

(c2b) comparing said top offset (o {k) Tn ) difference and said bottom offset (o (k) Bn ) 
difference yielding a greater top (o {k) Tn ) or bottom offset (o m Bn ) difference; and 

(c2c) if the top offset (o {k) Tn ) difference is greater than the bottom offset (o {k) Bn ) 
difference, assigning the lower index value for said column with a larger top offset 
10 (o m Tn ) difference. 

13. The method (99) according to claim 12 wherein step (c2b) is further 
characterized by the step of: 

(c2bl ) if the bottom offset (o (k) Bn ) difference is greater than the top offset (o ik) Tn ) 
difference, assigning the lower index value for said column with a larger bottom offset 
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14. The method (99) according to claim 13 wherein step (e) is further 
characterized by the step of forming said objective matrix( 39) as a decorrelator. 

15. The method (99) according to claim 13 wherein step (e) is further 
characterized by the step of forming said objective matrix (39) as a minimum mean 
square error detector. 

16. The method (99) according to claim 13 wherein step (e) is further 
characterized by the step of forming said objective matrix (39) as a zero-forcing block 
linear equalizer. 

17. The method (199) according to claim 10 wherein step (c) is further 
characterized by the steps of: 

(cl) grouping said system transmission response matrices according to like 
spreading factors (203); 
5 (c2) assembling spreading factor group transmission response matrices (205) 

from said groups of system transmission response matrices with like spreading factors; 
and 

(c3) forming a base total system response matrix (207) from a common spreading 
factor group matrix having the lowest spreading factor. 
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18. The method (1 99) according to claim 17 is further characterized by the steps 

of: 

(c4) choosing one spreading factor group transmission response matrix for 
consideration from said remaining spreading factor group matrices (209); 

(c5) deriving a column placement reference (211) for a first column of said 
chosen spreading factor group transmission response matrix; 

(c6) deriving a reference location (217) in said base total system transmission 
response matrix; 

(c7) deriving a column set (219) from said chosen spreading factor group 
transmission response matrix; 

(c8) inserting said column set after said column placement reference in said base 
total system response matrix (221); 

(c9) repeating steps (c5) through (c8) for each successive column of said 
spreading factor group transmission response matrix under consideration; and 

(clO) repeating steps (c5) through (c8) (223) for remaining spreading factor 
group matrices. 

19. The method (199) according to claim 18 wherein step (c5) is further 
characterized by the step of: 

(c5a) assigning a column placement reference index m (21 1) for said spreading 
factor group matrix under consideration using, 
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Q(g) Q(S) 

m = n — — — 

QiD 2 .Q(D 

where g w denotes the spreading factor associated with the spreading factor group 
transmission matrix under consideration, Q {1) denotes the lowest spreading factor among 
all groups and n is the column of the spreading factor group transmission response 
matrix under consideration where n = 1, 2, 3, .... 

20. The method (199) according to claim 19 is further characterized by the step 
of rounding said column placement reference index m (215) if not an integer. 

21. The method (199) according to claim 20 wherein step (c6) is further 
characterized by the step of: 

(c6a) assigning a reference location in said base total system transmission 
response matrix (217) using, 

m x L (1) 

where L (,) is total number of system transmission response matrices that constitute said 
spreading factor group matrix having the lowest spreading factor and m is said column 
placement reference index for said spreading factor group matrix under consideration. 

22. The method (199) according to claim 21 wherein step (c7) is further 
characterized by the step of: 
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(c7a) assigning a column set from said spreading factor group transmission 
response matrix under consideration (219) using, 

L w x (#i - 1) + 1 through L w x n 
where L w is said number of system transmission response matrices comprising said 
spreading factor group transmission matrix under consideration. 

23. The method (199) according to claim 22 wherein step (e) is further 
characterized by forming said objective matrix (39) as a decorrelator. 

24. The method (199) according to claim 22 wherein step (e) is further 
characterized by forming said objective matrix (39) as a minimum mean square error 
detector. 

25. The method (199) according to claim 22 wherein step (e) is further 
characterized by forming said objective matrix (39) as a zero-forcing block linear 
equalizer. 

26. A method of detecting in a received CDMA communication (r) a plurality 
of user (k) data communications (cf k) ), each user data communication (c£ k) ) having same 
or different spreading factors (Q {k) ), characterized by the steps of: 

(a) acquiring impulse estimates (19) corresponding with each symbol in each of 
the plurality of user data communications; 
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(b) constructing a system transmission response matrix (27) for each of the 
plurality of user data communications ((f k) ) from said respective impulse response 
estimates (19); 

(c) assembling a well-banded total system transmission response matrix (3 1 , 33, 
37) from all of said system transmission response matrices; 

(d) filtering (25) the received CDMA communication (r) with said arranged total 
system transmission response matrix yielding estimated data outputs; 

(e) forming an objective matrix (39) from said arranged total system response 
matrix; 

(f) inverting (41) said objective matrix; 

(g) multiplying (43) said estimated outputs with said inverted objective matrix 
yielding user data corresponding to the plurality of user data communications; and 

(h) repeating steps (a)-(g) for a next CDMA communication. 

27. The method (99) according to claim 26 wherein step (c) is further 
characterized by the steps of: 

(cl) examining each column of said system transmission response matrices for 
top (£> ( *V») and bottom (<?%„) offsets; 

(c2) assigning an index value («,) from 1 to n for each of said examined columns 
based upon said columns having a small top offset (o m Tn ) with a large bottom offset 
(0%„) ^ said columns having a large top offset (o {k) Tn ) with a small bottom offset (<?%„) 
respectively; and 
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(c3) arranging said examined total system transmission response matrix columns 
10 in accordance with said index values (n f ) according to increasing magnitude. 



28. The method according to claim 27, wherein step (c2) is further characterized 
by the step of: 

(c2a) obtaining a difference between top offsets (o (k) T „) and a difference between 
bottom offsets (<?%„) for two columns if a first column has a larger top offset (o (k) T „) and 
5 a larger bottom offset (<?%„) than a second column; 

(c2b) comparing said top offset (o lk \„) difference and said bottom offset (o%„) 
difference yielding a greater top or bottom offset (o (k) Tn ) difference; and 

(c2c) if the top offset (o (k) Tn ) difference is greater than the bottom offset (<?%„) 
difference, assigning the lower index value for said column with a larger top offset 
10 (o ik) T „) difference. 

29. The method according to claim 28 wherein step (c2b) is further characterized 
by the step of: 

(c2bl ) if the bottom offset (<?%„) difference is greater than the top offset (<? ( *V„) 
difference, assigning the lower index value for said column with a larger bottom offset 
5 (o%„) difference. 

30. The method (99) according to claim 29 wherein step (e) is further 
characterized by the step of forming said objective matrix (39) as a decorrelator. 
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31. The method (99) according to claim 29 wherein step (e) is further 
characterized by the step of forming said objective matrix (39) as a minimum mean 
square error detector. 

32. The method (99) according to claim 29 wherein step (e) is further 
characterized by the step of forming said objective matrix (39) as a zero-forcing block 
linear equalizer. 

33. The method (199) according to claim 26 wherein step (c) is further 
characterized by the steps of: 

(cl) grouping said system transmission response matrices according to like 
spreading factors (203); 

(c2) assembling spreading factor group transmission response matrices (205) 
from said groups of system transmission response matrices with like spreading factors; 
and 

(c3) forming a base total system response matrix (207) from a common spreading 
factor group matrix having the lowest spreading factor. 

34. The method (199) according to claim 33 further comprising the steps of: 
(c4) choosing one spreading factor group transmission response matrix for 

consideration from said remaining spreading factor group matrices (209); 

(c5) deriving a column placement reference (211) for a first column of said 
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chosen spreading factor group transmission response matrix; 

(c6) deriving a reference location (217) in said base total system transmission 
response matrix; 

(c7) deriving a column set (219) from said chosen spreading factor group 
transmission response matrix; 

(c8) inserting said column set after said column placement reference in said base 
total system response matrix (221); 

(c9) repeating steps (c5) through (c8) for each successive column of said 
spreading factor group transmission response matrix under consideration; and 

(clO) repeating steps (c5) through (c8) (223) for remaining spreading factor 
group matrices. 

35. The method (199) according to claim 34 wherein step (c5) is further 
characterized by the step of: 

(c5a) assigning a column placement reference index m (21 1) for said spreading 
factor group matrix under consideration using, 

Q(i) Q(S) 

m = n — — — 

Qd) 2 . fi (i) 

where <g te) denotes the spreading factor associated with the spreading factor group 
transmission matrix under consideration, Q {1) denotes the lowest spreading factor among 
all groups and n is the column of the spreading factor group transmission response 
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36. The method (199) according to claim 35 is further characterized by the step 
of rounding said column placement reference index m (215) if not an integer. 

37. The method (199) according to claim 36 wherein step (c6) is further 
characterized by the step of: 

(c6a) assigning a reference location in said base total system transmission 
response matrix (217) using, 
5 m x L il) 

where L {1) is total number of system transmission response matrices that constitute said 
spreading factor group matrix having the lowest spreading factor and m is said column 
placement reference index for said spreading factor group matrix under consideration. 

38. The method (199) according to claim 37 wherein step (c7) is further 
characterized by the step of: 

(c7a) assigning a column set from said spreading factor group transmission 
response matrix under consideration (219) using, 
5 L w x(»-1)+1 through L»x« 

where is said number of system transmission response matrices comprising said 
spreading factor group transmission matrix under consideration. 
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39. The method (199) according to claim 38 wherein step (e) is further 
characterized by forming said objective matrix (39) as a decorrelator. 



40. The method (199) according to claim 38 wherein step (e) is further 
characterized by forming said objective matrix (39) as a minimum mean square error 
detector. 

41. The method (199) according to claim 38 wherein step (e) is further 
characterized by forming said objective matrix (39) as a zero-forcing block linear 
equalizer. 

42. A multiuser detector (17) that detects in a received CDMA communication 
(r) a plurality of user data communications (cfl k) ) characterized by: 

means for acquiring impulse estimates (19) corresponding with each symbol in 
each of the plurality of user data communications (<£ k) )\ 
5 means for assembling a system transmission response matrix (27) for each of the 

plurality of user data communications (d k) ) from said respective impulse response 
estimates; 

means for assembling a total system transmission response matrix (31) from all 
of said system transmission response matrices yielding a well-banded matrix; 
10 means for filtering (25) the received CDMA communication with said total 

system transmission response matrix yielding estimated data outputs; 
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means for forming an objective matrix (39) from said arranged total system 
response matrix; 

means for inverting (41) said objective matrix; and 

means for multiplying (43) said estimated outputs with said inverted objective 
matrix yielding user data (<f k) ) corresponding to the plurality of user data 
communications. 

43. The multiuser detector (17) according to claim 42 wherein said means for 
assembling an arranged total system transmission response matrix is further 
characterized by: 

means for examining (33) each of said total system transmission response matrix 
columns for top (o m Tn ) and bottom (o (k) Bn ) offsets; 

means for assigning (33) an index value (n,) from 1 to n for each of said examined 
columns based upon said columns having a small top offset (o (k) Tn ) with a large bottom 
offset (o%„) to said columns having a large top offset (o ik) Tn ) with a small bottom offset 
(° {k) Bn) respectively; and 

means for re-arranging said examined total system transmission response matrix 
columns in accordance with said index values (n,) according to increasing magnitude. 

44. The multiuser detector (17) according to claim 43 wherein said means for 
assigning is further characterized by: 

means for obtaining a difference between top offsets (o ik) Tn ) and a difference 
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between bottom offsets (o {k) Bn ) for two columns if a first column has a larger top offset 
5 (o {k) Tn ) and a larger bottom offset (o {k) Bn ) than a second column; 

means for comparing said top offset (o {k) Tlt ) difference and said bottom offset 
(o (k) Bn ) difference yielding a greater top (o {k) Tn ) or bottom (o {k) Bn ) offset difference; and 
means for assigning a lower index value (n y ) for said column with a larger top 
offset (o m Tn ) difference if the top offset (o {k) Tn ) difference is greater than the bottom 
10 offset (o {k) Bn ) difference. 

45. The multiuser detector according to claim 44 wherein said means for 
comparing is further characterized by means for assigning a lower index value (n,) for 
said column with a larger bottom offset (o {k) Bn ) difference if the bottom offset (o (k) Bn ) 
difference is greater than the top offset (o m Tn ) difference. 

46. The multiuser detector (17) according to claim 45 characterized in that said 
objective matrix is a decorrelator. 

47. The multiuser detector (17) according to claim 45 characterized in that said 
objective matrix is a minimum mean square error detector. 

48. The multiuser detector (17) according to claim 45 characterized in that said 
objective matrix is a zero-forcing block linear equalizer. 
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49. The multiuser detector (17) according to claim 42 wherein said means for 
assembling an arranged total system transmission response matrix (37) is further 
characterized by: 

means for grouping (33) said system transmission response matrices according 
to like spreading factors; 

means for assembling (33) spreading factor group transmission response matrices 
from said groups of system transmission response matrices with like spreading factors; 
and 

means for forming (33) a base total system response matrix from a common 
spreading factor group matrix having the lowest spreading factor. 

50. The multiuser detector (17) according to claim 49 is further characterized by: 
means for choosing (33) one spreading factor group transmission response matrix 

for consideration from said remaining spreading factor group matrices; 

means for deriving (33) a column placement reference for a first column of said 
chosen spreading factor matrix; 

means for deriving (33) a reference location in said base total system transmission 
response matrix; 

means for deriving (33) a column set from said chosen spreading factor group 
transmission response matrix; and 

means for inserting (33) said column set after said column placement reference 
in said base total system response matrix. 
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51. The multiuser detector (17) according to claim 50 wherein said means for 
deriving a column placement reference is further characterized by: 

means for assigning (33) a column placement reference index m for said 
spreading factor group matrix under consideration using, 

Q(8) Q(g) 

c m = n- — - — 

Q {) 2-Q il) 

where g w denotes the spreading factor associated with the spreading factor group 
transmission matrix under consideration, Q {1) denotes the lowest spreading factor among 
all groups and n is the column of the spreading factor group transmission response 
matrix under consideration where n = 1, 2, 3, .... 

52. The multiuser detector (17) according to claim 5 1 is further characterized by 
means for rounding said column placement reference index m if not an integer. 

53. The multiuser detector (17) according to claim 52 wherein said means for 
deriving a reference location is further characterized by: 

means for assigning a reference location (33) in said base total system 
transmission response matrix using, 
5 m x L (1) . 

where L (1) is total number of system transmission response matrices that constitute said 
spreading factor group matrix having the lowest spreading factor and m is said column 
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placement reference index for said spreading factor group matrix under consideration. 



54. The multiuser detector (17) according to claim 53 wherein said means for 
deriving a column set is further characterized by: 

means for assigning a column set (33) from said spreading factor group 
transmission response matrix under consideration using, 

L^x(/i - 1)+ 1 through L^xn 
where is said number of system transmission response matrices comprising said 
spreading factor group transmission matrix under consideration. 

55. The multiuser detector (17) according to claim 54 wherein said means for 
forming an objective matrix is further characterized by forming said objective matrix as 
a decorrelator. 

56. The multiuser detector (17) according to claim 54 wherein said means for 
forming an objective matrix is further characterized by forming said objective matrix as 
a minimum mean square error detector. 

57. The multiuser detector (17) according to claim 54 wherein said means for 
forming an objective matrix is further characterized by forming said objective matrix as 
a zero-forcing block linear equalizer. 
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